home *** CD-ROM | disk | FTP | other *** search
/ Skunkware 98 / Skunkware 98.iso / src / mail / pine3.96.tar.gz / pine3.96.tar / pine3.96 / imap / non-ANSI / c-client / nl_unix.c < prev    next >
C/C++ Source or Header  |  1994-10-09  |  3KB  |  106 lines

  1. /*
  2.  * Program:    UNIX/VMS newline routines
  3.  *
  4.  * Author:    Mark Crispin
  5.  *        Networks and Distributed Computing
  6.  *        Computing & Communications
  7.  *        University of Washington
  8.  *        Administration Building, AG-44
  9.  *        Seattle, WA  98195
  10.  *        Internet: MRC@CAC.Washington.EDU
  11.  *
  12.  * Date:    1 August 1988
  13.  * Last Edited:    9 October 1994
  14.  *
  15.  * Copyright 1994 by the University of Washington
  16.  *
  17.  *  Permission to use, copy, modify, and distribute this software and its
  18.  * documentation for any purpose and without fee is hereby granted, provided
  19.  * that the above copyright notice appears in all copies and that both the
  20.  * above copyright notice and this permission notice appear in supporting
  21.  * documentation, and that the name of the University of Washington not be
  22.  * used in advertising or publicity pertaining to distribution of the software
  23.  * without specific, written prior permission.  This software is made available
  24.  * "as is", and
  25.  * THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
  26.  * WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED
  27.  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN
  28.  * NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL,
  29.  * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  30.  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT
  31.  * (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION
  32.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  33.  *
  34.  */
  35.  
  36. /* Copy string with CRLF newlines
  37.  * Accepts: destination string
  38.  *        pointer to size of destination string buffer
  39.  *        source string
  40.  *        length of source string
  41.  * Returns: length of copied string
  42.  */
  43.  
  44. unsigned long strcrlfcpy (dst,dstl,src,srcl)
  45.     char **dst;
  46.     unsigned long *dstl;
  47.     char *src;
  48.                    unsigned long srcl;
  49. {
  50.   long i,j;
  51.   char *d = src;
  52.                 /* count number of LF's in source string(s) */
  53.   for (i = srcl,j = 0; j < srcl; j++) if (*d++ == '\012') i++;
  54.                 /* flush destination buffer if too small */
  55.   if (*dst && (i > *dstl)) fs_give ((void **) dst);
  56.   if (!*dst) {            /* make a new buffer if needed */
  57.     *dst = (char *) fs_get ((*dstl = i) + 1);
  58.     if (dstl) *dstl = i;    /* return new buffer length to main program */
  59.   }
  60.   d = *dst;            /* destination string */
  61.                 /* copy strings, inserting CR's before LF's */
  62.   while (srcl--) switch (*src) {
  63.   case '\015':            /* unlikely carriage return */
  64.     *d++ = *src++;        /* copy it and any succeeding linefeed */
  65.     if (srcl && *src == '\012') {
  66.       *d++ = *src++;
  67.       srcl--;
  68.     }
  69.     break;
  70.   case '\012':            /* line feed? */
  71.     *d++ ='\015';        /* yes, prepend a CR, drop into default case */
  72.   default:            /* ordinary chararacter */
  73.     *d++ = *src++;        /* just copy character */
  74.     break;
  75.   }
  76.   *d = '\0';            /* tie off destination */
  77.   return d - *dst;        /* return length */
  78. }
  79.  
  80. /* Length of string after strcrlfcpy applied
  81.  * Accepts: source string
  82.  * Returns: length of string
  83.  */
  84.  
  85. unsigned long strcrlflen (s)
  86.     STRING *s;
  87. {
  88.   unsigned long pos = GETPOS (s);
  89.   unsigned long i = SIZE (s);
  90.   unsigned long j = i;
  91.   while (j--) switch (SNX (s)) {/* search for newlines */
  92.   case '\015':            /* unlikely carriage return */
  93.     if (j && (CHR (s) == '\012')) {
  94.       SNX (s);            /* eat the line feed */
  95.       j--;
  96.     }
  97.     break;
  98.   case '\012':            /* line feed? */
  99.     i++;
  100.   default:            /* ordinary chararacter */
  101.     break;
  102.   }
  103.   SETPOS (s,pos);        /* restore old position */
  104.   return i;
  105. }
  106.